<template>
  <div class="bg">
    <div class="content">
      <div class="l-left">
        <div class="desc">
          <div class="title">
            KSO.vue<span style="
                font-size: 13px;
                background: #46c706;
                border-radius: 24px;
                padding: 4px 9px;
                border: 1px solid;
                margin-left: 5px;
              ">vue3.x</span>
          </div>
          <p>.NetCore、EntityFrameWorkCore、Dapper</p>
          <p>Redis、mongoDB、RabbitMQ、Doeker </p>
          <p>Vue、ECharts、Vuex、 ElementUI-Plus</p>
          <p>账号：KSO &nbsp; &nbsp; &nbsp; 密码:123456</p>
          <div style="margin-top: 32px" class="link">
            <a href="https://gitee.com/kong-shaobo/ksovue" target="_blank">
              <span>Gitee前端</span></a>
            <a href="https://gitee.com/kong-shaobo/KSOAdmin" target="_blank">
              <span>Gitee后端</span></a>
          </div>
        </div>
      </div>
      <div class="login">
        <div class="login-contianer">
          <div class="login-form">
            <h2>账号登录</h2>
            <div class="v-tag">Vue3.x版本</div>
            <div class="form-user" @keypress="loginPress">
              <div class="item">
                <div class="f-text">
                  <label> 用户名： </label>
                </div>
                <div class="f-input">
                  <input type="text" v-focus v-model="userInfo.UserName" placeholder="输入用户" />
                </div>
              </div>
              <div class="item">
                <div class="f-text">
                  <label> 密&nbsp;&nbsp;&nbsp;码： </label>
                </div>
                <div class="f-input">
                  <input type="password" v-focus v-model="userInfo.UserPwd" placeholder="输入密码" />
                </div>
              </div>
              <div class="item">
                <div class="f-text">
                  <label> 验证码： </label>
                </div>
                <div class="f-input">
                  <input v-focus type="text" v-model="userInfo.UserVerification" placeholder="输入验证码" />
                </div>
                <div class="code" @click="getVierificationCode">
                  <img v-show="codeImgSrc != ''" :src="codeImgSrc" />
                </div>
              </div>
            </div>
            <div class="loging-btn">
              <el-button size="large" :loading="loading" type="success" @click="login" long>
                <span v-if="!loading">一键登录</span>
                <span v-else>正在登录...</span>
              </el-button>
            </div>
            <div class="app-link">
            </div>
          </div>
        </div>
      </div>
    </div>
    <div class="l-bg"></div>
    <div class="r-bg"></div>

    <div class="login-footer">
      <a @click="openUrl('http://60.205.178.29:8103/#/')">
        KSO前端地址
      </a>
      <a @click="openUrl('http://60.205.178.29:8102/swagger/index.html')">
        KSO后端地址
      </a>
      <a href="https://space.bilibili.com/525836469" style="text-decoration: none"
        target="blank">NET视频教程(微软MVP-ACE录制)</a>
      <a href="http://v2.volcore.xyz/document/guide" style="text-decoration: none" target="blank">VOL文档地址</a>
    </div>
  </div>
</template>
<script>
import {
  defineComponent,
  ref,
  reactive,
  toRefs,
  getCurrentInstance,
} from "vue";
import { useRouter, useRoute } from "vue-router";
import store from "../store/index";
import { VerificationCode, Logins } from "@/../src/api/system/login.js";
import KsoAdmin from "../uitils/tools";
export default defineComponent({
  setup(props, context) {
    const loading = ref(false);
    const codeImgSrc = ref("");
    const userInfo = reactive({
      UserName: "",
      UserPwd: "",
      UserVerification: "",
      UUID: undefined,
    });

    const getVierificationCode = () => {
      VerificationCode("KSOAdminLogin").then((result) => {
        if (result.code === 200) {
          codeImgSrc.value = "data:image/png;base64," + result.data.img;
          userInfo.UUID = result.data.uuid;
        }
      });
    };
    getVierificationCode();

    let appContext = getCurrentInstance().appContext;
    let $message = appContext.config.globalProperties.$message;
    let router = useRouter();

    const login = () => {

      // 正式开发请删掉
      userInfo.UserName = "KSO";
      userInfo.UserPwd = "123456";
      userInfo.UserVerification = "111";
      // 正式开发请删掉

      if (!userInfo.UserName) return $message.error("请输入用户名");
      if (!userInfo.UserPwd) return $message.error("请输入密码");
      if (!userInfo.UserVerification) return $message.error("请输入验证码");
      userInfo.UserPwd = KsoAdmin.md5(userInfo.UserPwd);
      loading.value = true;
      Logins(userInfo).then((result) => {
        debugger
        if (result.code !== 200) {
          loading.value = false;
          getVierificationCode();
          return $message.error(result.message);
        }
        $message.success("登录成功,正在跳转!");
        store.commit("setUserInfo", result.data);
        router.push({ path: "/" });
      });
    };

    const loginPress = (e) => {
      if (e.keyCode == 13) {
        login();
      }
    };
    const openUrl = (url) => {
      window.open(url, "_blank");
    };
    return {
      loading,
      codeImgSrc,
      userInfo,

      loginPress,
      openUrl,
      getVierificationCode,
      login,
    };
  },
  directives: {
    focus: {
      inserted: function (el) {
        el.focus();
      },
    },
  },
});
</script>

<style lang="less" scoped>
.bg {
  display: flex;
  overflow: hidden;
  position: relative;
  height: 100%;
  width: 100%;
  background-image: linear-gradient(135deg, #4e8e2f 10%, #4e8e2f);
}

.login {
  flex: 1;
}

.loging-btn {
  button {
    width: 100%;
  }
}

.content {
  display: flex;
  z-index: 99;
  position: relative;
  width: 860px;
  left: 0;
  right: 0;

  margin: 0 auto;
  transform: translateY(-50%);
  // background: #dedede40;
  top: 50%;
  height: 400px;
  border-radius: 10px;

  .l-left {
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
    width: 400px;
    // background-image: linear-gradient(135deg, #0d82ff 10%, #0cd7bd);
    // border: 1px solid #5c87ff;
  }
}

.desc {
  text-align: left;
  width: 450px;
  padding: 10px 30px;
  box-sizing: border-box;
  height: 100%;
}

.desc p {
  font-size: 15px;
  color: white;
  line-height: 30px;
}

.desc p:before {
  top: -1px;
  content: "o";
  position: relative;
  margin-right: 7px;
}

.title {
  z-index: 999;
  font-size: 70px;
  font-weight: bold;
  color: white;
}

.l-bg {
  height: 1200px;
  width: 1200px;
  border-radius: 50%;
  background: #67C23A;
  position: absolute;
  top: -700px;
  left: -700px;
  background-image: linear-gradient(135deg, #67C23A 10%, #67C23A);
}

.r-bg {
  height: 2000px;
  width: 2000px;
  border-radius: 50%;
  background: #67C23A;
  position: absolute;
  top: -1500px;
  right: -900px;
  background-image: linear-gradient(135deg, #85ce61 10%, #85ce61);
}
</style>

<style lang="less" scoped>
.form-user {
  margin: 25px 0;

  .item {
    display: flex;
    padding-bottom: 5px;
    border-bottom: 1px solid #eee;
    margin-bottom: 30px;
    display: flex;

    .f-text {
      color: #484848;
      font-weight: 400;
      width: 110px;
      font-size: 16px;
      text-align: left;

      i {
        position: relative;
        top: -1px;
        right: 5px;
      }
    }

    .f-input {
      border: 0px;
      flex: 1;
    }

    .code {
      position: relative;
      cursor: pointer;
      top: -5px;
      width: 74px;
      border: 1px solid #fdfdfd;
      border-radius: 2px;
      height: 35px;
      margin-left: 10px;
    }
  }
}

input:-webkit-autofill {
  box-shadow: 0 0 0px 1000px white inset;
}

.login-contianer {
  .login-form {
    position: relative;
    overflow: hidden;
    // margin-top: 25px;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
    padding: 10px 30px 40px 30px;
    width: 400px;
    min-height: 340px;
    background: white;
    height: 400px;
    box-shadow: 2px 5px 18px #6453534a;

    h2 {
      font-weight: 500;
      padding: 10px 0px;
      text-align: left;
      margin-top: 15px;
    }

    .v-tag {
      top: -23px;
      text-align: center;
      position: absolute;
      right: -43px;
      line-height: 49px;
      top: -17px;
      padding-left: 21px;
      font-size: 12px;
      width: 158px;
      background: #4e8e2f;
      padding-top: 25px;
      color: white;
      -webkit-transform: rotate(40deg);
      letter-spacing: 2px;
    }
  }
}

.loging-btn {
  margin-top: 20px;
}

.action {
  text-align: right;
  margin-top: 20px;
  font-size: 12px;
  color: #9c9c9c;
  cursor: pointer;

  a {
    margin-left: 20px;
  }
}

.login-footer {
  cursor: pointer;
  padding: 10px;
  text-align: center;
  font-size: 14px;
  position: absolute;
  width: 100%;
  bottom: 0px;
  background: #4e8e2f;
  border-top: 1px solid #e2e2e2;

  i {
    position: relative;
    top: -2px;
    margin-right: 5px;
  }

  a {
    margin-left: 30px;
    color: #f9ebd0;
  }
}

@media screen and (max-width: 600px) {
  .desc {
    display: none;
  }

  .bg {
    background-image: none;
  }

  .login-form {
    box-shadow: none !important;
  }

  .login-form {
    width: 100% !important;
  }

  .login-footer,
  .r-bg,
  .l-bg {
    display: none;
  }

  .l-left {
    display: none;
  }

  .c-bg-item {
    background: none !important;
  }
}

.link a {
  text-decoration: none;

  color: #ffff;
  border: 1px solid #ffff;
  width: 80px;
  margin-right: 5px;
  display: inline-block;
  margin-bottom: 0;
  font-weight: 400;
  text-align: center;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;

  white-space: nowrap;
  user-select: none;
  padding: 5px 15px 6px;
  font-size: 12px;
  border-radius: 32px;
}
</style>
<style scoped>
input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px white inset !important;
}

input {
  background: white;
  display: block;
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  margin: 0;
  padding: 0;
  color: #323233;
  line-height: inherit;
  text-align: left;
  border: 0;
  outline: none;
  font-size: 16px;
  line-height: 20px;
}
</style>
<style lang="less" scoped>
.c-bg {
  position: absolute;
  width: 100%;
  height: 200px;

  .c-bg-item {
    width: 25%;
    background: #00a7f5;
    height: 200px;
  }
}

.app-link {
  text-align: center;
  padding-top: 21px;
  font-size: 14px;

  a {
    position: relative;
    cursor: pointer;
    width: 70px;
    color: #1483f6;
    margin: 20px 20px 0 0;
  }

  img {
    display: none;
  }

  a:hover {
    img {
      display: block;
      position: absolute;
      z-index: 999999999;
      top: -130px;
      width: 120px;
      left: -22px;
      border: 1px solid #b1b1b1;
    }
  }
}
</style>
